Amendments to the Claims: 

Claims 1, 3, 4, 1 1, 13, 20, and 26-28 are currently being amended. . 
New claims 37-40 are being added. 

This amendment adds, changes and/or deletes claims in this application. A detailed 
listing of all claims that are, or were, in the application, irrespective of whether the claim(s) 
remain under examination in the apphcation, are presented. The text of all claims presently 
under examination is presented below in the listing of claims, and all claims are presented with 
an appropriate defined status identifier. 
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Detailed and Complete Listing of Claims: „ : 

P^, (Currently Amended) A system for managing licenses for protected software on a 
communication network, the system comprising: 

at least one client computer coupled to the communication network for requesting 
authorizations to use the protected software; and 

a pool of license servers coupled to the communication network, each license server 
programmed for managing a distribution of one or more allocations to at least one client 
computer to use the protected software and for maintaining a record of distribution , the pool of 
license servers including a current leader server programmed for maintaining a record of 
allocations for license servers in the poo L wherein upon selecting a new leader server from the 
pool the new leader server further programmed for receiving from each license server the record 
of distribution for that Hcense server. 




^ (Original) A system as recited in claim 1, the pool of license servers further including at least 
one follower server, each follower server programmed for managing the distribution of 
allocations for that particular follower server. 



^ (Currently Amended) A system for managing licenses for protected software on a 
communication network, the system comprising: 

® at least one client computer coupled to the communicatioii network for requesting 
authorizations to use the protected software; and 

6) a pool of license servers coupled to the communication network, each license server 
programmed for managing a distribution of one or more allocations to at least one client 
computer to use the protected software, the pool of license servers including a current leader 
server programmed for maintaining a record of allocations for license servers in the pool; 

wherein the pool of license servers includes at least one follower server, each follower 
server programmed for managing the distribution of allocations for that particular follower 
server; 

wherein each license server includes memory for storing a status of the allocations for 
that particular license server; and 
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wherein each follower server is programmed for communicating the status of the 
allocations for that particular follower server to the current leader server , and wherein upon 
selecting a new leader server from the pool the new leader server further programmed for 
receiving from each Ucense server the status of allocations for that particular license server . 

(Currently Amended) A system for managing licenses for protected software on a 
communication network, the system comprising: 

0 at least one client computer coupled to the commimication network for requesting 
authorizations to use the protected software; and 

(D a pool of license servers coupled to the communication network, each license server 
programmed for managing a distribution of one or more allocations to at least one client 
computer to use the protected software and for maintaining a record of distribution, the pool of 
license servers including a current leader server programmed for maintaining a record of 
allocations for Hcense servers in the pool; 

@ wherein the pool of Ucense servers includes at least one follower server; 
C wherein each follower server is programmed such that it is capable of becoming a new 

leader server if the current leader server can no longer manage the distribution of allocations for 

^ Q 

the license server ^ and wherein upon selecting a new leader server from the pool the new leader 
server fiirther programmed for receiving from each license server the record of distribution for 
that license server . 

(Previously Amended) A system as recited in claim 4, wherein the pool 
of license servers are programmed for communicating with each other and determining when a 
particular hcense server can no longer manage a distribution of allocations to use the protected 
software. 

/^T" (Original) A system as recited in claim 1, wherein the license servers are programmed for 
preventing the issuance of an authorization to use protected software unless a majority of license 
servers are functioning and capable of managing a distribution of allocations to use the protected 
software. 
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p( (Original) A system as recited in claim 5, wherein each client computer that has received an 
authorization from a particular license server, and the particular Ucense server that sent the 
authorization to the client computer, are programmed for communicating heartbeats between 
each other; and 

wherein each client computer that has received an authorization from a particular license 
server is programmed for determining whether that particular license server is still capable of 
managing a distribution of allocations to use the protected software. 

X (Original) A system as recited in claim 7, wherein each client computer that has received an 
authorization from a particular license server but has determined that particular license server is 
no longer capable of managing a distribution of allocations to use the protected software is 
programmed for: 

locating a new leader server; and 

communicating a heartbeat from the client computer to the new leader server. 

^ (Original) A system as recited in claim 8, wherein if the new leader server receives, a 
heartbeat from a client computer that has located the new leader server, the new leader server is 
programmed for: 

determining if the new leader server had aheady issued an authorization to the client 
computer; and 

converting the heartbeat to a request for an authorization if the new leader server had not 
aheady issued an authorization to the client computer. 

(Original) A system as recited in claim 5, each Ucense server ftirther including memory for 
storing a Ucense file and sequence number; 

wherein if a particular license server is no longer capable of managing a distribution of 
allocations to use the protected software, the memory in the particular Ucense server is capable of 
receiving a new redundant license file and a new sequence number; and 

wherein if the particular license server is brought back on line and if the new sequence 
number is greater than any sequence number currently stored in the memory of the other Ucense 



.2 



5 




servers in the pool, the particular license server and the other hcense servers in the pool are 
programmed for transferring the new redundant license file to other Kcense servers in the pool. 

J^, (Currently Amended) A method for managing licenses for protected software on a 
communication network, the method comprising: 

coupling at least one client computer to the communication network for enabling the at 
least one client computer to issue a request for an authorization to use the protected software 
over the communication network; 

coupling a pool of license servers to the communication network, each license server 
managing a distribution of allocations to at least one client computer to use the protected 
software; aed 

selecting one of the licerise servers in the pool as a current leader server and maintaining 
a record of allocations for license servers in the pool with the current leader server^ 
selecting a new leader server from the pool of license servers, and 
transmitting the distribution of allocations of each licensed server to the new leader 

server . 

J^. (Original) A method as recited in claim 11, further including the steps of: 

designating other license servers that are not the current leader server as follower servers; 

and 

managing the distribution of allocations for each follower server with that particular 
follower server. 

]Z. (Currently Amended) A method for managing licenses for protected software on a 
communication network, the method comprising: 

coupling at least one client computer to the communication network for enabling the at 
least one client computer to issue a request for an authorization to use the protected software 
over the communication network; 

coupling a pool of hcense servers to the communication network, each license server 
managing a distribution of allocations to at least one client computer to use the protected 
software; 
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selecting one of the license servers in the pool as a current leader server and maintaining 
a record of allocations for license servers in the pool with the current leader server; 

designating other license servers that are not the current leader server as follower servers; 

managing the distribution of allocations for each follower server with that particular 
follower server; 

storing a status of the allocations for each hcense server within each license server; 
communicating the status of the allocations for each follower server to the current leader 

server^ 

selecting a new leader server from the pool of hcense servers; and 

transmitting the status of allocations of each hcensed server to the new leader server . 

)X. (Previously Amended) A method as recited in claim 20, further including the step of 
determining, by communications between the pool of hcense servers, when a particular license 
server can no longer manage a distribution of allocations to use the protected software. 

jS^ (Original) A method as recited in claim 11, further including the step of preventing license 
servers from issuing authorizations to use protected software unless a majority of license servers 
in the pool are functioning and capable of managing a distribution of allocations to use the 
protected software. 

MT (Original) A method as recited in claim 14, further including the steps of: 

communicating heartbeats between client computers that have received an authorization 

from a particular license server and that particular license server; and 

determining, for each client computer that has received an authorization from a particular 

hcense server, if that particular license server is still capable of managing a distribution of 

allocations to use the protected software. 

(Original) A method as recited in claim 16, wherein for each chent computer that has 
received an authorization from a particular hcense server but has determined that particular 
license server is no longer capable of managing a distribution of allocations to use the protected 
software, the method further includes the steps of: 
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locating the new leader server; and 

conununi eating a heartbeat jfrom the client computer to the new leader server. 

]^ (Original) A method as recited in claim 17, wherein if the new leader server receives a 
heartbeat from a client computer that has located the new leader server, the method further 
includes the steps of: 

determining if the new leader server had already issued an authorization to the client 
computer; and 

converting the heartbeat to a request for an authorization if the new leader server had not 
already issued an authorization to the client computer. 

J^(Original) A method as recited in claim 14, further including the steps of: 

storing a redundant license file and sequence number within each license server; 
storing a new redundant license file and a new sequence number in a particular license 

server that is no longer capable of managing a distribution of allocations to use the protected 

software; 

restoring functionaUty to the particular license server that was no longer capable of 
managing a distribution of allocations to use the protected software; and 

transferring the new redundant Ucense file to other license servers in the pool if the new 
sequence number is greater than any sequence number currently stored in any other license 
server in the pool. 



(Currently Amended) A method for managing licenses for protected software on a 
communication network, the method comprising: 



least one client computer to issue a request for an authorization to use the protected software 
over the communication network; 

coupling a pool of license servers to the communication network, each license server 
managing a distribution of allocations to at least one client computer to use the protected 
software and managing a record of allocations : 




coupling at least one client computer to the communication network for enabling the at 
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selecting one of the license servers in the pool as a current leader server and maintaining 
a record of allocations for license servers in the pool with the current leader server; 

designating other license servers that are not the current leader server as follower servers; 

UIJU. 

selecting one of the follower servers as a new leader server whenever the current leader 
server can no longer manage the distribution of allocations for the license servers , and 

transmitting the record of allocations for each license server to the new leader server . 

/f. (Previously added) A system as recited in claim 4, wherein the current leader server is 
programmed for communicating a heartbeat to each follower server; 

wherein each follower server is programmed for communicating an acknowledgement to 
the current leader server in response to the heartbeat; and 

wherein the current leader server designates a follower server as being down if no 
acknowledgement is received from that follower server. 

^ (Previously added) A system as recited in claim 4, wherein the current leader server is 

C programmed for communicating a heartbeat to each follower server; 
I wherein if a follower server does not receive the heartbeat from the current leader, then 

the follower server that did not receive the heartbeat sends a check message to the current leader; 
and 

wherein if the follower server that did not receive the heartbeat does not receive a 
response from the current leader in reply to the check message, then the follower server that did 
not receive the heartbeat starts an election process to elect a new current leader. 

;24^. (Previously added) A system as recited in claim 4, wherein if a follower server becomes the 
new leader server, then the new leader server sends a heartbeat to each of the remaining follower 
servers; and 

wherein each of the remaining follower servers communicates the status of the 
allocations for that particular follower server to the new leader server. 
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(Previously added) A system as recited in claim 1, wherein the first license server to begin 
operation in the pool of Ucense servers is designated as the current leader server. 



^ (Previously added) A system as recited in claim 3, wherein the current leader server 

maintains a list that indicates whether or not each particular follower server is in operation; 
wherein the current leader server sends the list to each follower server; and 
wherein the follower servers use the information contained in the list to select a new 

leader server if the current leader server can no longer manage the distribution of allocations for 

the license servers. 

26. (Currently amended) A Gystcm as rocitod in Claim 5, A svstem for managing licenses for 
protected software on a communication network, the svstem comprising: 

' at least one client co mputer coupled to the communication network for requesting 

authorizations to use the protected software: and 0 

a pool of Ucense server s coupled to the communication network, each license server 

programmed for mana ging a distribution of one or more allocations to at least one cUent 
computer to use the pro tected software, the pool of license servers including a current leader 
server programmed for maintaining a record of allocations for license servers in the pool: ^ 

wherein the pool of license servers includes at least one follower server: 0 

wherein each follower server is programmed such that it is capable of becoming a new 

leade r server if the current leader server can no longer manage the distribution of allocations for 
the Hcense servers: ^ 

wherein the pool of H cense servers are programmed for communicating with each other 

and determining when a particular license server can no longer manage a distribution of 
allocations to use the protected software: & 

wherein each client computer that has received an authorization ft-om a particular license 
server, and the particular license server that sent the authorization to the client computer, are 
programmed for communicating heartbeats between each other; 

wherein each client computer that has received an authorization from a particular hcense 
server also receives a leader priority list from that particular license server; 
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wherein each client computer that has received an authorization jfrom a particular license 
server is programmed for determining whether that particular license server is still capable of 
managing a distribution of allocations to use the protected software; and 



server but has determined that particular license server is no longer capable of managing a 
distribution of allocations to use the protected software is programmed for locating another 
license server by using the leader priority list. 



^ (Currently amended) A system as recitod in claim L A system for managing licenses for 
protected software on a communication network, the system comprising: 

^ at least one client computer coupled to the commimication network for requesting 
authorizations to use the protected software: and 

^ a pool of license servers coupled to the communication network, each Ucense server 
programmed for managing a distribution of one or more allocations to at least one client 
computer to use the protected software, the pool of license servers including a current leader 
server programmed for maintaining a record of allocations for license servers in the pool: 

wherein the current leader server manages a distribution of allocations to more than one 
client computer to use the protected software. 



\^ (Currently amended) A system as r e cited in claim 2. A system for managing licenses for 
protected software on a communication network, the system comprising: 

at least one client computer coupled to the communication network for requesting 

authorizations to use the protected software: and 

a pool of license servers coupled to the communication network, each license server 

program med for managing a distribution of one or more allocations to at least one client 
computer to use the protected software, the pool of license servers including a current leader 
server pro grammed for maintaining a record of allocations for license servers in the pool: the 
poo] of license servers ftirther including at least one follower server, each follower server 
programmed for managing the distribution of allocations for that particular follower server: 
wherein a first follower server authorizes a first client computer to use the protected 
software; and 



wherein each client computer that has received an authorization fi-om a~particular license 





wherein the current leader server authorizes a second client computer to use the protected 
software. . 

^ (Previously added) A method as recited in claim 20, further including the steps of: 
communicating a heartbeat from the current leader server to each follower server; 
communicating an acknowledgement from each follower server to the current leader 

server in response to the heartbeat; and 

designating a follower server as being down if no acknowledgement is received from that 

follower server. 

/q, (Previously added) A method as recited in claim 20, further including the steps of: 
communicating a heartbeat from the current leader server to each follower server; 
sending a check, message to the current leader server from each follower server that does 

not receive the heartbeat from the current leader server; and 

starting an election process at each follower server that does not receive a response to the 

check message from tlie current leader server in order to elect a new current leader server. 

(Previously added) A method as recited in claim 20, further including the steps of: 

sending a heartbeat from the follower server that is selected as the new leader server to 
each of the remaining follower servers when the current leader server can no longer manage the 
distribution of allocations for the hcense servers; 

communicating the status of allocations for each remaining follower server to the new 
leader server in response to the heartbeat sent from the new leader server. 

^ (Previously added) A method as recited in claim 1 1 , wherein the step of selecting one of the 
license servers in the pool as a current leader server comprises: 

selecting the first license server to start operation as the current leader server. 

33. (Previously added) A method as recited in claim 13, further including the steps of 

maintaining a list with the current leader server indicating whether or not each of the 
follower servers is in operation; 
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sending the Ust from the current leader server to each of the follower servers; and 
using the information contained in the list to select a new leader server if the current 
leader server can no longer manage the distribution of allocations for the license servers. 

@ (Previously added) A method as recited in claim 14, further including the steps of: 

)(, communicating heartbeats between client computers that have received an authorization 
from a particular license server and that particular hcense server; 

?.t> communicating a leader priority list from license servers to the client computers to which 
they send authorizations; 

detemiining, for each client computer that has received an authorization from a particular 
license server, if that particular license server is still capable of managing a distribution of 
allocations to use the protected software; and 

ih locating, for each client computer that has received an authorization from a particular 
license server but has determined that particular license server is no longer capable of managing 
a distribution of allocations to use the protected software, another hcense server by using the 
leader priority hst. 

B5) (Previously added) A method as recited in claim 1 1 , wherein the current leader server 
-2.0 manages a distribution of allocations to more than one client computer to use the protected 
software. 

3^ (Previously added) A method as recited in claim 12, further including the steps of: 

authorizing, from a first follower server, a first client computer to use the protected 
software; and 

authorizing, from the current leader server, a second client computer to use the protected 
software. 



37. (New) A system as recited in claim 1, wherein the. new leader is programmed for 
/\ i\y transmitting a signal to each license sender in the pool identifying itself as the new current leader, 
^ and receiving the record of distribution in response to the transmitted signal. 
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38. (New) A system as recited in claim 1, wherein upon receipt of the record of distribution 
from each Hcense server, the new leader is programmed for amending its record of distribution to 
include the record of distribution for each Hcense server such that a new record of allocations for 
the licensed servers in the pool is created on the new leader. 

39. (New) A system as recited in claim 3, wherein upon receipt of the status of allocations from 
each license server, the new leader is programmed for amending its status of allocations to 




include the status of allocations for each hcense server such that a new record of allocations for 
the licensed servers in the pool is created on the new leader. 



40. (New) A system as recited in claim 4, wherein upon receipt of the record of distribution 
from each license server, the new leader is programmed for amending its record of distribution to 
include the record of distribution for each license server such that a new record of allocations for 
the hcensed servers in the pool is created on the new leader. 
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